<template>
  <el-scrollbar class="side-bar-container student" :class="{ 'is-collapse': collapse }">
    <!--    <vab-logo />-->
    <el-menu
      background-color="#121418"
      text-color="#ffffff"
      active-text-color="#ffffff"
      :default-active="activeMenu"
      :collapse="collapse"
      :collapse-transition="false"
      :default-openeds="defaultOpens"
      :unique-opened="uniqueOpened"
      mode="vertical"
    >
      <template v-for="route in routes">
        <vab-side-bar-item
          v-if="route.children && route.children.length > 0"
          :key="route.path"
          :full-path="route.path"
          :item="route"
        />
      </template>
    </el-menu>
  </el-scrollbar>
</template>
<script>
import variables from '@/styles/variables.scss'
import { mapGetters } from 'vuex'
import { defaultOopeneds, uniqueOpened } from '@/config'
import VabSideBarItem from '@/layouts/components/VabSideBar/components/VabSideBarItem'
export default {
  name: 'VabSideBar2',
  components: { VabSideBarItem },
  data() {
    return {
      title: this.$baseTitle,
      uniqueOpened
    }
  },
  computed: {
    ...mapGetters({
      logo: 'settings/logo',
      collapse: 'settings/collapse',
      routes: 'routes/routes'
    }),
    defaultOpens() {
      /* if (this.collapse) {
      }*/
      return defaultOopeneds
    },
    activeMenu() {
      const route = this.$route
      const { meta, path } = route
      if (meta['activeMenu']) {
        return meta['activeMenu']
      }
      return path
    },
    variables() {
      return variables
    }
  }
}
</script>
<style lang="scss" scoped>
@mixin active {
  &:hover {
    color: $base-color-white;
    background-color: $base-menu-background-active !important;
  }

  &.is-active {
    color: $base-color-white;
    background-color: $base-menu-background-active !important;
  }
}

.side-bar-container {
  position: fixed;
  top: $base-nav-bar-height;
  bottom: 0;
  left: 0;
  z-index: $base-z-index;
  width: $base-left-menu-width;
  height: 100vh;
  overflow: hidden;
  background: $base-menu-background;
  transition: $base-transition;

  &.is-collapse {
    width: $base-left-menu-width-min;
    border-right: 0;

    ::v-deep {
      .el-menu {
        transition: $base-transition;
      }

      .el-menu--collapse {
        border-right: 0;

        .el-submenu__icon-arrow {
          right: 10px;
          margin-top: -3px;
        }

        .el-menu-item,
        .el-submenu {
          text-align: center;

        }

        .el-menu-item,
        .el-submenu__title {
          padding-left: 0 !important;
          padding-right: 0 !important;
        }
      }
    }
  }

  ::v-deep {
    .el-scrollbar__wrap {
      overflow-x: hidden;
    }

    .el-menu {
      border: 0;

      .vab-fas-icon {
        padding-right: 3px;
        font-size: $base-font-size-default;
        display: inline-block;
        width: 14px;
      }

      .vab-remix-icon {
        padding-right: 3px;
        font-size: $base-font-size-default + 2;
      }
    }

    .el-menu-item,
    .el-submenu__title {
      height: $base-menu-item-height;
      line-height: $base-menu-item-height;
      vertical-align: middle;
    }

    .el-menu-item {
      @include active;
    }
  }
}

.student {
  background: none;

  ::v-deep {
    .el-menu {
      background: none;
    }
  }
}
</style>
